Coverage Report

Created: 2024-12-19 06:34

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
D:\a\tools.proto\tools.proto\compiler\src\gen\base\message_write.rs
Line
Count
Source
1
// Copyright (c) 2024, BlockProject 3D
2
//
3
// All rights reserved.
4
//
5
// Redistribution and use in source and binary forms, with or without modification,
6
// are permitted provided that the following conditions are met:
7
//
8
//     * Redistributions of source code must retain the above copyright notice,
9
//       this list of conditions and the following disclaimer.
10
//     * Redistributions in binary form must reproduce the above copyright notice,
11
//       this list of conditions and the following disclaimer in the documentation
12
//       and/or other materials provided with the distribution.
13
//     * Neither the name of BlockProject 3D nor the names of its contributors
14
//       may be used to endorse or promote products derived from this software
15
//       without specific prior written permission.
16
//
17
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
18
// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
19
// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
20
// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR
21
// CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
22
// EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
23
// PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
24
// PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
25
// LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
26
// NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
27
// SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
28
29
use crate::compiler::message::{Field, Message};
30
use crate::compiler::util::types::TypeMapper;
31
use crate::gen::base::map::TypePathMapper;
32
use crate::gen::base::message::{Templates, Utilities};
33
use crate::gen::base::message_common::generate_field_type_inline;
34
use crate::gen::base::Error;
35
36
66
fn gen_field_write_impl<U: Utilities, T: TypeMapper>(
37
66
    field: &Field,
38
66
    templates: &Templates,
39
66
    type_path_map: &TypePathMapper<T>,
40
66
    function: &str,
41
66
) -> Result<String, Error> {
42
66
    let mut scope = templates.template.scope();
43
66
    scope.var("name", &field.name);
44
66
    let codec_template = templates.get(field.codec())
?0
;
45
66
    let msg_type = generate_field_type_inline::<U, T>(field, codec_template, type_path_map, "write")
?0
;
46
66
    if let Some(
header13
) = &field.header {
  Branch (46:12): [True: 13, False: 53]
  Branch (46:12): [True: 0, False: 0]
  Branch (46:12): [Folded - Ignored]
47
13
        scope.var("header_name", &header.name);
48
53
    }
49
66
    scope.var("type", msg_type);
50
66
    if field.header.is_some() && 
field.ty.is_union()13
{
  Branch (50:8): [True: 13, False: 53]
  Branch (50:34): [True: 9, False: 4]
  Branch (50:8): [True: 0, False: 0]
  Branch (50:34): [True: 0, False: 0]
  Branch (50:8): [Folded - Ignored]
  Branch (50:34): [Folded - Ignored]
51
9
        Ok(scope.render(function, &["field_union"]).unwrap())
52
57
    } else if field.header.is_some() {
  Branch (52:15): [True: 4, False: 53]
  Branch (52:15): [True: 0, False: 0]
  Branch (52:15): [Folded - Ignored]
53
4
        Ok(scope.render(function, &["field_header"]).unwrap())
54
53
    } else if field.ty.is_string() {
  Branch (54:15): [True: 18, False: 35]
  Branch (54:15): [True: 0, False: 0]
  Branch (54:15): [Folded - Ignored]
55
18
        Ok(scope.render(function, &["field_string"]).unwrap())
56
    } else {
57
35
        Ok(scope.render(function, &["field"]).unwrap())
58
    }
59
66
}
60
61
35
pub fn generate<'variable, U: Utilities, T: TypeMapper>(
62
35
    mut templates: Templates<'_, 'variable>,
63
35
    msg: &'variable Message,
64
35
    type_path_map: &TypePathMapper<T>,
65
35
    function: &str,
66
35
) -> Result<String, Error> {
67
35
    templates.template.var("msg_name", &msg.name);
68
35
    let fields = msg
69
35
        .fields
70
35
        .iter()
71
66
        .map(|field| gen_field_write_impl::<U, T>(field, &templates, type_path_map, function))
72
35
        .collect::<Result<Vec<String>, Error>>()
?0
73
35
        .join("");
74
35
    Ok(templates.template.var("fields", fields).render("", &[function]).unwrap())
75
35
}